package com.psycho.sys.api.mapper;

import com.baomidou.mybatisplus.core.mapper.BaseMapper;
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
import com.psycho.sys.api.entity.User;
import com.psycho.sys.api.vo.UserVO;
import org.apache.ibatis.annotations.Mapper;
import org.apache.ibatis.annotations.Param;

/**
 * 用户数据访问层
 */
@Mapper
public interface UserMapper extends BaseMapper<User> {
    /**
     * 分页查询用户列表（包含角色信息）
     */
    Page<UserVO> selectUserWithRole(Page<UserVO> page,
            @Param("username") String username,
            @Param("realName") String realName,
            @Param("userType") Integer userType,
            @Param("status") Integer status);

    /**
     * 根据用户名查询用户信息
     */
    User selectByUsername(@Param("username") String username);

    /**
     * 更新用户状态
     */
    int updateUserStatus(@Param("userId") Long userId, @Param("status") Integer status);

    /**
     * 更新用户最后登录时间
     */
    int updateLastLoginTime(@Param("userId") Long userId);

    /**
     * 统计用户数量（按类型）
     */
    Integer countUsersByType(@Param("userType") Integer userType);

    /**
     * 统计活跃用户数量
     */
    Integer countActiveUsers(@Param("startTime") String startTime, @Param("endTime") String endTime);
}